// Copyright (c) 2010, SMB SAAS Systems Inc.
// All rights reserved.
//
// Redistribution and use in source and binary forms, with or without modification,
// are permitted provided that the following conditions are met:
//
// - Redistributions of source code must  retain  the  above copyright notice, this
//   list of conditions and the following disclaimer.
//
// - Redistributions in binary form  must  reproduce the  above  copyright  notice,
//   this list of conditions  and  the  following  disclaimer in  the documentation
//   and/or other materials provided with the distribution.
//
// - Neither  the  name  of  the  SMB SAAS Systems Inc.  nor   the   names  of  its
//   contributors may be used to endorse or  promote  products  derived  from  this
//   software without specific prior written permission.
//
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
// ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING,  BUT  NOT  LIMITED TO, THE IMPLIED
// WARRANTIES  OF  MERCHANTABILITY   AND  FITNESS  FOR  A  PARTICULAR  PURPOSE  ARE
// DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR
// ANY DIRECT, INDIRECT, INCIDENTAL,  SPECIAL,  EXEMPLARY, OR CONSEQUENTIAL DAMAGES
// (INCLUDING, BUT NOT LIMITED TO,  PROCUREMENT  OF  SUBSTITUTE  GOODS OR SERVICES;
// LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)  HOWEVER  CAUSED AND ON
// ANY  THEORY  OF  LIABILITY,  WHETHER  IN  CONTRACT,  STRICT  LIABILITY,  OR TORT
// (INCLUDING NEGLIGENCE OR OTHERWISE)  ARISING  IN  ANY WAY OUT OF THE USE OF THIS
// SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.

using System;
using dotPanel.Providers.Common;
using dotPanel.Server.Utils;

namespace dotPanel.Providers.HostedSolution
{
    public class HostedSolutionLog
    {
        internal static string LogPrefix = "HostedSolution";

		internal static void LogStart(string message, params object[] args)
		{
			string text = String.Format(message, args);
			Log.WriteStart("{0} {1}", LogPrefix, text);
		}

		internal static void LogEnd(string message, params object[] args)
		{
			string text = String.Format(message, args);
			Log.WriteEnd("{0} {1}", LogPrefix, text);
		}

		internal static void LogInfo(string message, params object[] args)
		{
			string text = String.Format(message, args);
			Log.WriteInfo("{0} {1}", LogPrefix, text);
		}

		internal static void LogWarning(string message, params object[] args)
		{
			string text = String.Format(message, args);
			Log.WriteWarning("{0} {1}", LogPrefix, text);
		}

		internal static void LogError(Exception ex)
		{
			Log.WriteError(LogPrefix, ex);
		}

		internal static void LogError(string message, Exception ex)
		{
			string text = String.Format("{0} {1}", LogPrefix, message);
			Log.WriteError(text, ex);
		}

		internal static void DebugInfo(string message, params object[] args)
		{
#if DEBUG
			string text = String.Format(message, args);
			Log.WriteInfo("{0} {1}", LogPrefix, text);
#endif
		}

        internal static void EndLog(string message, ResultObject res, string errorCode, Exception ex)
        {
            if (res != null)
            {
                res.IsSuccess = false;

                if (!string.IsNullOrEmpty(errorCode))
                    res.ErrorCodes.Add(errorCode);
            }

            if (ex != null)
                LogError(ex);


            //LogRecord.
            LogEnd(message);


        }

        internal static void EndLog(string message, ResultObject res, string errorCode)
        {
            EndLog(message, res, errorCode, null);
        }

        internal static void EndLog(string message, ResultObject res)
        {
            EndLog(message, res, null);
        }

        internal static void EndLog(string message)
        {
            EndLog(message, null);
        }

        internal static T StartLog<T>(string message) where T : ResultObject, new()
        {
            LogStart(message);
            T res = new T();
            res.IsSuccess = true;
            return res;
        }
		
	}
}
